<template>
  <a-row :gutter="24">
    <a-col :md="24">
      <a-card :style="cardStyle" :bordered="false">
        <!-- 查询区域 -->
        <div class="table-page-search-wrapper">
          <!-- 搜索区域 -->
          <a-form layout="inline" @keyup.enter.native="searchQuery">
            <a-row :gutter="24">
              <a-col :md="6" :sm="24">
                <a-form-item label="单据编号" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-input placeholder="请输入单据编号" v-model="queryParam.orderNo"></a-input>
                </a-form-item>
              </a-col>
              <a-col :md="6" :sm="24">
                <a-form-item label="单据日期" :labelCol="labelCol" :wrapperCol="wrapperCol">
                  <a-range-picker
                    style="width: 100%"
                    v-model="queryParam.createTimeRange"
                    format="YYYY-MM-DD"
                    :placeholder="['开始时间', '结束时间']"
                    @change="onDateChange"
                    @ok="onDateOk"
                  />
                </a-form-item>
              </a-col>
              <span style="float: left; overflow: hidden" class="table-page-search-submitButtons">
                <a-col :md="6" :sm="24">
                  <a-button type="primary" @click="searchQuery">查询</a-button>
                  <a-button style="margin-left: 8px" @click="searchReset">重置</a-button>
                  <a @click="handleToggleSearch" style="margin-left: 8px">
                    {{ toggleSearchStatus ? '收起' : '展开' }}
                    <a-icon :type="toggleSearchStatus ? 'up' : 'down'" />
                  </a>
                </a-col>
              </span>
              <template v-if="toggleSearchStatus">
                <a-col :md="6" :sm="24">
                  <a-form-item label="交货方式" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select
                      placeholder="请选择交货方式"
                      showSearch
                      optionFilterProp="children"
                      v-model="queryParam.deliveryMethod"
                    >
                      <a-select-option v-for="(item, index) in deliveryMethodList" :key="index" :value="item">
                        {{ item }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="供应商" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select
                      placeholder="请选择供应商"
                      showSearch
                      optionFilterProp="children"
                      v-model="queryParam.supplierId"
                    >
                      <a-select-option v-for="(item, index) in supList" :key="index" :value="item.id">
                        {{ item.name }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="业务员" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select
                      placeholder="请选择业务员"
                      showSearch
                      optionFilterProp="children"
                      v-model="queryParam.salesmanId"
                    >
                      <a-select-option v-for="(item, index) in userList" :key="index" :value="item.id">
                        {{ item.name }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="审核员" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select
                      placeholder="请选择审核员"
                      showSearch
                      optionFilterProp="children"
                      v-model="queryParam.auditorId"
                    >
                      <a-select-option v-for="(item, index) in userList" :key="index" :value="item.id">
                        {{ item.name }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                  <a-col :md="6" :sm="24">
                  <a-form-item label="结算账户" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select
                      placeholder="请选择结算账户"
                      showSearch
                      optionFilterProp="children"
                      v-model="queryParam.settlementAccountId"
                    >
                      <a-select-option v-for="(item, index) in accountList" :key="index" :value="item.id">
                        {{ item.name }}
                      </a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="付款状态" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select placeholder="请选择单据状态" v-model="queryParam.paymentStatus">
                      <a-select-option value="已付款">已付款</a-select-option>
                      <a-select-option value="未付款">未付款</a-select-option>
                      <a-select-option value="部分付款">部分付款</a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="退款状态" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select placeholder="请选择单据状态" v-model="queryParam.returnStatus">
                      <a-select-option value="未退款">未退款</a-select-option>
                      <a-select-option value="已退款">已退款</a-select-option>
                      <a-select-option value="部分退款">部分退款</a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="审核状态" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-select placeholder="请选择单据状态" v-model="queryParam.isAudited">
                      <a-select-option value="0">未审核</a-select-option>
                      <a-select-option value="1">已审核</a-select-option>
                    </a-select>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="退货单号" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-input placeholder="请选择退货单号" v-model="reTurnPurchaseReturnOrderNo" disabled>
                      <a-button slot="addonAfter" @click="handReturnChoose" icon="plus">选择</a-button>
                    </a-input>
                  </a-form-item>
                </a-col>
                <a-col :md="6" :sm="24">
                  <a-form-item label="单据备注" :labelCol="labelCol" :wrapperCol="wrapperCol">
                    <a-input placeholder="请输入单据备注" v-model="queryParam.remark"></a-input>
                  </a-form-item>
                </a-col>
              </template>
            </a-row>
          </a-form>
        </div>
        <!-- 操作按钮区域 -->
        <div class="table-operator" style="margin-top: 5px">
          <a-button @click="myHandleAdd" type="primary" icon="plus">新增</a-button>
          <a-button icon="delete" @click="batchDel">删除</a-button>
          <a-button icon="check" @click="batchSetStatus(1)">审核</a-button>
          <a-button icon="stop" @click="batchSetStatus(0)">反审核</a-button>
          <a-button v-if="isShowExcel && btnEnableList.indexOf(3) > -1" icon="download" @click="handleExport"
            >导出</a-button
          >
          <a-popover trigger="click" placement="right">
            <template slot="content">
              <a-checkbox-group @change="onColChange" v-model="settingDataIndex" :defaultValue="settingDataIndex">
                <a-row style="width: 500px">
                  <template v-for="(item, index) in defColumns">
                    <template>
                      <a-col :span="8" v-if="purchaseBySaleFlag">
                        <a-checkbox :value="item.dataIndex">
                          <j-ellipsis :value="item.title" :length="10"></j-ellipsis>
                        </a-checkbox>
                      </a-col>
                      <a-col :span="8" v-if="!purchaseBySaleFlag && item.dataIndex !== 'linkNumber'">
                        <a-checkbox :value="item.dataIndex">
                          <j-ellipsis :value="item.title" :length="10"></j-ellipsis>
                        </a-checkbox>
                      </a-col>
                    </template>
                  </template>
                </a-row>
                <a-row style="padding-top: 10px">
                  <a-col>
                    恢复默认列配置：<a-button @click="handleRestDefault" type="link" size="small">恢复默认</a-button>
                  </a-col>
                </a-row>
              </a-checkbox-group>
            </template>
            <a-button icon="setting">列设置</a-button>
          </a-popover>
          <!-- <a-tooltip
            placement="left"
            title="采购订单不涉及付款金额，采购订单可以转采购入库单，但需要先对采购订单进行审核。
          勾选单据之后可以进行批量操作（删除、审核、反审核）"
            slot="action"
          >
            <a-icon type="question-circle" style="font-size: 20px; float: right" />
          </a-tooltip> -->
        </div>
        <!-- table区域-begin -->
        <div>
          <a-table
            ref="table"
            size="middle"
            bordered
            rowKey="id"
            :columns="columns"
            :dataSource="dataSource"
            :components="handleDrag(columns)"
            :pagination="ipagination"
            :scroll="scroll"
            :loading="loading"
            :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange }"
            @change="handleTableChange"
          >
            <span slot="action" slot-scope="text, record">
              <a @click="myHandleDetail(record, '采购订单', prefixNo)">查看</a>
              <a-divider type="vertical" />
              <a @click="myHandleEdit(record,'purchase')">编辑</a>
              <a-divider type="vertical" />
              <a @click="myHandleCopyAdd(record)">复制</a>
              <a-divider type="vertical" />
              <a-popconfirm title="确定删除吗?" @confirm="() => myHandleDelete(record)">
                <a>删除</a>
              </a-popconfirm>
            </span>
            <template slot="customRenderStatus" slot-scope="isAudited">
              <a-tag v-if="isAudited == null || isAudited == '0'" color="red">未审核</a-tag>
              <a-tag v-if="isAudited == '1'" color="green">已审核</a-tag>
            </template>
            <span slot="logistics" slot-scope="text, record">
              <div v-if="record.logisticsNo != null && record.logisticsNo != ''" style="text-align: center">
                {{ record.logisticsNo }}
                <a-button type="primary"   @click="myHandlelogistics(record)">查看物流</a-button>
              </div>
            </span>
          </a-table>
        </div>
        <!-- table区域-end -->
        <!-- 表单区域 -->
        <Logistics key="logistics" ref="logistics" @ok="modalFormOk"></Logistics>
        <purchase-order-modal ref="modalForm" @ok="modalFormOk" @close="modalFormClose"></purchase-order-modal>
        <bill-detail ref="modalDetail" @ok="modalFormOk" @close="modalFormClose"></bill-detail>
        <bill-excel-iframe ref="billExcelIframe" @ok="modalFormOk" @close="modalFormClose"></bill-excel-iframe>
        <purchase-return-order-choose
          ref="purchaseReturnOrderChoose"
          @choose="reTurnPurchaseReturnOrder"
        ></purchase-return-order-choose>
      </a-card>
    </a-col>
  </a-row>
</template>
<!-- by  ji  sheng  hua-->
<script>
import PurchaseOrderModal from './modules/PurchaseOrderModal'
import PurchaseReturnOrderChoose from './choose/PurchaseReturnOrderChoose.vue'
import BillDetail from './dialog/BillDetail'
import BillExcelIframe from '@/components/tools/BillExcelIframe'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import { BillListMixin } from './mixins/BillListMixin'
import JEllipsis from '@/components/jeecg/JEllipsis'
import JDate from '@/components/jeecg/JDate'
import Vue from 'vue'
import Logistics from './dialog/Logistics'

export default {
  name: 'PurchaseOrderList',
  mixins: [JeecgListMixin, BillListMixin],
  components: {
    PurchaseOrderModal,
    BillDetail,
    BillExcelIframe,
    JEllipsis,
    JDate,
    Logistics,
    PurchaseReturnOrderChoose,
  },
  data() {
    return {
      reTurnPurchaseReturnOrderNo: '',
      // 查询条件
      queryParam: {
        //TODO：帐户，物流id
        // orderNo: '',
        // beginTime: '',
        // endTime: '',
        // deliveryMethod: '',
        // paymentStatus: '',
        // returnStatus: '',
        // isAudited: '',
        // salesmanId: '',
        // purchaseReturnOrderId: '',
        // settlementAccountId: '',
        // auditorId: '',
        // logisticsId: '',
        // supplierId: '',
      },
      prefixNo: 'CGDD',
      labelCol: {
        span: 5,
      },
      wrapperCol: {
        span: 18,
        offset: 1,
      },
      // 默认索引
      defDataIndex: [
        'action',
        'orderNo',
        'orderDate',
        'purchaseAmount',
        'discountRate',
        'discountAmount',
        'quantity',
        'amountAfterDiscount',
        'paidAmount',
        'deliveryMethod',
        'paymentStatus',
        'returnStatus',
        'isAudited',
        'remark',
        'supplierName',
        'supplierAddress',
        'salesmanName',
        'purchaseReturnOrderId',
        'purchaseReturnOrderNo',
        'settlementAccountId',
        'settlementAccountName',
        'isAllocated',
        'auditorId',
        'auditorName',
        'logisticsNo',
      ],
      // 默认列
      defColumns: [
        {
          title: '操作',
          dataIndex: 'action',
          align: 'center',
          width: 180,
          scopedSlots: { customRender: 'action' },
        },
        {
          title: '单据编号',
          dataIndex: 'orderNo',
          width: 160,
        },
        { title: '单据日期', dataIndex: 'orderDate', width: 120 },
        { title: '购货价格', dataIndex: 'purchaseAmount', width: 60 },
        {
          title: '优惠率',
          dataIndex: 'discountRate',
          width: 60,
          customRender: function (text, record, index) {
            return text ? text + '%' : ''
          },
        },
        { title: '优惠金额', dataIndex: 'discountAmount', width: 60 },
        { title: '数量', dataIndex: 'quantity', width: 60 },
        { title: '折后金额', dataIndex: 'amountAfterDiscount', width: 60 },
        { title: '已付款金额', dataIndex: 'paidAmount', width: 60 },
        { title: '送货方式', dataIndex: 'deliveryMethod', width: 60 },
        { title: '付款状态', dataIndex: 'paymentStatus', width: 100 },
        { title: '退货状态', dataIndex: 'returnStatus', width: 60 },
        { title: '审核状态', dataIndex: 'isAudited', width: 80, scopedSlots: { customRender: 'customRenderStatus' } },
        { title: '备注', dataIndex: 'remark', width: 60 },
        { title: '供应商', dataIndex: 'supplierName', width: 160 },
        { title: '送货地址', dataIndex: 'supplierAddress', width: 180 },
        { title: '业务员', dataIndex: 'salesmanName', width: 60 },
        { title: '结算账户', dataIndex: 'settlementAccountName', width: 120 },
        { title: '审核人', dataIndex: 'auditorName', width: 60 },
           { title: '退货单号', dataIndex: 'purchaseReturnOrderNo', width: 120 },
        { title: '物流单号', dataIndex: 'logisticsNo', width: 100, scopedSlots: { customRender: 'logistics' } },
      ],
      url: {
        list: '/purchaseOrder/list',
        delete: '/purchaseOrder/delete',
        deleteBatch: '/purchaseOrder/deleteBatch',
        batchSetStatusUrl: '/purchaseOrder/batchSetStatus',
      },
    }
  },
  created() {
    this.initDeliveryMethod()
    // this.initSystemConfig()
    this.initSupplier()
    this.initUser()
        this.initAccount()
  },

  computed: {},

  methods: {
    handReturnChoose() {
      this.$refs.purchaseReturnOrderChoose.show()
    },
    reTurnPurchaseReturnOrder(data) {
      this.queryParam.purchaseReturnOrderId = data.id
      this.reTurnPurchaseReturnOrderNo = data.orderNo
    },
    searchReset() {
      this.resetqueryParam()
      this.loadData(1)
      this.reTurnPurchaseReturnOrderNo = ''
    },
  },
}
</script>
<style scoped>
@import '~@assets/less/common.less';
</style>